;;; Compiled by f2cl version:
;;; ("$Id: f2cl1.l,v 1.209 2008/09/11 14:59:55 rtoy Exp $"
;;;  "$Id: f2cl2.l,v 1.37 2008/02/22 22:19:33 rtoy Rel $"
;;;  "$Id: f2cl3.l,v 1.6 2008/02/22 22:19:33 rtoy Rel $"
;;;  "$Id: f2cl4.l,v 1.7 2008/02/22 22:19:34 rtoy Rel $"
;;;  "$Id: f2cl5.l,v 1.197 2008/09/11 15:03:25 rtoy Exp $"
;;;  "$Id: f2cl6.l,v 1.48 2008/08/24 00:56:27 rtoy Exp $"
;;;  "$Id: macros.l,v 1.106 2008/09/15 15:27:36 rtoy Exp $")

;;; Using Lisp International Allegro CL Enterprise Edition 8.1 [64-bit Linux (x86-64)] (Oct 7, 2008 17:13)
;;;
;;; Options: ((:prune-labels nil) (:auto-save t)
;;;           (:relaxed-array-decls t) (:coerce-assigns :as-needed)
;;;           (:array-type ':array) (:array-slicing t)
;;;           (:declare-common nil) (:float-format double-float))

(in-package :clml.blas)


(let* ((one 1.0) (zero 0.0))
  (declare (type (double-float 1.0 1.0) one)
   (type (double-float 0.0 0.0) zero) (ignorable one zero))
  (defun dgemv (trans m n alpha a lda x incx beta y incy)
    (declare (type (double-float) beta alpha)
     (type (array double-float (*)) y x a)
     (type (simple-array character (*)) trans)
     (type (f2cl-lib:integer4) incy incx lda n m))
    (f2cl-lib:with-multi-array-data ((trans character trans-%data%
                                      trans-%offset%)
                                     (a double-float a-%data%
                                      a-%offset%)
                                     (x double-float x-%data%
                                      x-%offset%)
                                     (y double-float y-%data%
                                      y-%offset%))
      (prog ((i 0) (info 0) (ix 0) (iy 0) (j 0) (jx 0) (jy 0) (kx 0)
             (ky 0) (lenx 0) (leny 0) (temp 0.0))
            (declare (type (double-float) temp)
             (type (f2cl-lib:integer4) i info ix iy j jx jy kx ky lenx
              leny))
            (setf info 0)
            (cond ((and (not (lsame trans "N")) (not (lsame trans "T"))
                        (not (lsame trans "C")))
                   (setf info 1))
                  ((< m 0) (setf info 2))
                  ((< n 0) (setf info 3))
                  ((< lda
                      (max (the f2cl-lib:integer4 1)
                           (the f2cl-lib:integer4 m)))
                   (setf info 6))
                  ((= incx 0) (setf info 8))
                  ((= incy 0) (setf info 11)))
            (cond ((/= info 0) (xerbla "DGEMV " info) (go end_label)))
            (if (or (= m 0) (= n 0) (and (= alpha zero) (= beta one)))
                (go end_label))
            (cond ((lsame trans "N") (setf lenx n) (setf leny m))
                  (t (setf lenx m) (setf leny n)))
            (cond ((> incx 0) (setf kx 1))
                  (t
                   (setf kx
                         (f2cl-lib:int-sub 1
                                           (f2cl-lib:int-mul (f2cl-lib:int-sub lenx
                                                                               1)
                                                             incx)))))
            (cond ((> incy 0) (setf ky 1))
                  (t
                   (setf ky
                         (f2cl-lib:int-sub 1
                                           (f2cl-lib:int-mul (f2cl-lib:int-sub leny
                                                                               1)
                                                             incy)))))
            (cond ((/= beta one)
                   (cond ((= incy 1)
                          (cond ((= beta zero)
                                 (f2cl-lib:fdo (i 1
                                                (f2cl-lib:int-add i 1))
                                               ((> i leny) nil)
                                               (tagbody
                                                   (setf (f2cl-lib:fref y-%data%
                                                                        (i)
                                                                        ((1
                                                                          *))
                                                                        y-%offset%)
                                                         zero)
                                                 label10)))
                                (t
                                 (f2cl-lib:fdo (i 1
                                                (f2cl-lib:int-add i 1))
                                               ((> i leny) nil)
                                               (tagbody
                                                   (setf (f2cl-lib:fref y-%data%
                                                                        (i)
                                                                        ((1
                                                                          *))
                                                                        y-%offset%)
                                                         (* beta
                                                            (f2cl-lib:fref y-%data%
                                                                           (i)
                                                                           ((1
                                                                             *))
                                                                           y-%offset%)))
                                                 label20)))))
                         (t
                          (setf iy ky)
                          (cond ((= beta zero)
                                 (f2cl-lib:fdo (i 1
                                                (f2cl-lib:int-add i 1))
                                               ((> i leny) nil)
                                               (tagbody
                                                   (setf (f2cl-lib:fref y-%data%
                                                                        (iy)
                                                                        ((1
                                                                          *))
                                                                        y-%offset%)
                                                         zero)
                                                   (setf iy
                                                         (f2cl-lib:int-add iy
                                                                           incy))
                                                 label30)))
                                (t
                                 (f2cl-lib:fdo (i 1
                                                (f2cl-lib:int-add i 1))
                                               ((> i leny) nil)
                                               (tagbody
                                                   (setf (f2cl-lib:fref y-%data%
                                                                        (iy)
                                                                        ((1
                                                                          *))
                                                                        y-%offset%)
                                                         (* beta
                                                            (f2cl-lib:fref y-%data%
                                                                           (iy)
                                                                           ((1
                                                                             *))
                                                                           y-%offset%)))
                                                   (setf iy
                                                         (f2cl-lib:int-add iy
                                                                           incy))
                                                 label40))))))))
            (if (= alpha zero) (go end_label))
            (cond ((lsame trans "N")
                   (setf jx kx)
                   (cond ((= incy 1)
                          (f2cl-lib:fdo (j 1 (f2cl-lib:int-add j 1))
                                        ((> j n) nil)
                                        (tagbody
                                            (cond ((/= (f2cl-lib:fref x
                                                                      (jx)
                                                                      ((1
                                                                        *)))
                                                       zero)
                                                   (setf temp
                                                         (* alpha
                                                            (f2cl-lib:fref x-%data%
                                                                           (jx)
                                                                           ((1
                                                                             *))
                                                                           x-%offset%)))
                                                   (f2cl-lib:fdo (i 1
                                                                  (f2cl-lib:int-add i
                                                                                    1))
                                                                 ((> i
                                                                     m)
                                                                  nil)
                                                                 (tagbody
                                                                     (setf (f2cl-lib:fref y-%data%
                                                                                          (i)
                                                                                          ((1
                                                                                            *))
                                                                                          y-%offset%)
                                                                           (+ (f2cl-lib:fref y-%data%
                                                                                             (i)
                                                                                             ((1
                                                                                               *))
                                                                                             y-%offset%)
                                                                              (* temp
                                                                                 (f2cl-lib:fref a-%data%
                                                                                                (i
                                                                                                 j)
                                                                                                ((1
                                                                                                  lda)
                                                                                                 (1
                                                                                                  *))
                                                                                                a-%offset%))))
                                                                   label50))))
                                            (setf jx
                                                  (f2cl-lib:int-add jx
                                                                    incx))
                                          label60)))
                         (t
                          (f2cl-lib:fdo (j 1 (f2cl-lib:int-add j 1))
                                        ((> j n) nil)
                                        (tagbody
                                            (cond ((/= (f2cl-lib:fref x
                                                                      (jx)
                                                                      ((1
                                                                        *)))
                                                       zero)
                                                   (setf temp
                                                         (* alpha
                                                            (f2cl-lib:fref x-%data%
                                                                           (jx)
                                                                           ((1
                                                                             *))
                                                                           x-%offset%)))
                                                   (setf iy ky)
                                                   (f2cl-lib:fdo (i 1
                                                                  (f2cl-lib:int-add i
                                                                                    1))
                                                                 ((> i
                                                                     m)
                                                                  nil)
                                                                 (tagbody
                                                                     (setf (f2cl-lib:fref y-%data%
                                                                                          (iy)
                                                                                          ((1
                                                                                            *))
                                                                                          y-%offset%)
                                                                           (+ (f2cl-lib:fref y-%data%
                                                                                             (iy)
                                                                                             ((1
                                                                                               *))
                                                                                             y-%offset%)
                                                                              (* temp
                                                                                 (f2cl-lib:fref a-%data%
                                                                                                (i
                                                                                                 j)
                                                                                                ((1
                                                                                                  lda)
                                                                                                 (1
                                                                                                  *))
                                                                                                a-%offset%))))
                                                                     (setf iy
                                                                           (f2cl-lib:int-add iy
                                                                                             incy))
                                                                   label70))))
                                            (setf jx
                                                  (f2cl-lib:int-add jx
                                                                    incx))
                                          label80)))))
                  (t
                   (setf jy ky)
                   (cond ((= incx 1)
                          (f2cl-lib:fdo (j 1 (f2cl-lib:int-add j 1))
                                        ((> j n) nil)
                                        (tagbody
                                            (setf temp zero)
                                            (f2cl-lib:fdo (i 1
                                                           (f2cl-lib:int-add i
                                                                             1))
                                                          ((> i m) nil)
                                                          (tagbody
                                                              (setf temp
                                                                    (+ temp
                                                                       (* (f2cl-lib:fref a-%data%
                                                                                         (i
                                                                                          j)
                                                                                         ((1
                                                                                           lda)
                                                                                          (1
                                                                                           *))
                                                                                         a-%offset%)
                                                                          (f2cl-lib:fref x-%data%
                                                                                         (i)
                                                                                         ((1
                                                                                           *))
                                                                                         x-%offset%))))
                                                            label90))
                                            (setf (f2cl-lib:fref y-%data%
                                                                 (jy)
                                                                 ((1
                                                                   *))
                                                                 y-%offset%)
                                                  (+ (f2cl-lib:fref y-%data%
                                                                    (jy)
                                                                    ((1
                                                                      *))
                                                                    y-%offset%)
                                                     (* alpha temp)))
                                            (setf jy
                                                  (f2cl-lib:int-add jy
                                                                    incy))
                                          label100)))
                         (t
                          (f2cl-lib:fdo (j 1 (f2cl-lib:int-add j 1))
                                        ((> j n) nil)
                                        (tagbody
                                            (setf temp zero)
                                            (setf ix kx)
                                            (f2cl-lib:fdo (i 1
                                                           (f2cl-lib:int-add i
                                                                             1))
                                                          ((> i m) nil)
                                                          (tagbody
                                                              (setf temp
                                                                    (+ temp
                                                                       (* (f2cl-lib:fref a-%data%
                                                                                         (i
                                                                                          j)
                                                                                         ((1
                                                                                           lda)
                                                                                          (1
                                                                                           *))
                                                                                         a-%offset%)
                                                                          (f2cl-lib:fref x-%data%
                                                                                         (ix)
                                                                                         ((1
                                                                                           *))
                                                                                         x-%offset%))))
                                                              (setf ix
                                                                    (f2cl-lib:int-add ix
                                                                                      incx))
                                                            label110))
                                            (setf (f2cl-lib:fref y-%data%
                                                                 (jy)
                                                                 ((1
                                                                   *))
                                                                 y-%offset%)
                                                  (+ (f2cl-lib:fref y-%data%
                                                                    (jy)
                                                                    ((1
                                                                      *))
                                                                    y-%offset%)
                                                     (* alpha temp)))
                                            (setf jy
                                                  (f2cl-lib:int-add jy
                                                                    incy))
                                          label120))))))
            (go end_label)
       end_label (return (values nil nil nil nil nil nil nil nil nil
                                 nil nil))))))

(in-package #-gcl #:cl-user #+gcl "CL-USER")
#+#.(cl:if (cl:find-package '#:f2cl) '(and) '(or))
(eval-when (:load-toplevel :compile-toplevel :execute)
  (setf (gethash 'fortran-to-lisp::dgemv
                 fortran-to-lisp::*f2cl-function-info*)
        (fortran-to-lisp::make-f2cl-finfo :arg-types '((simple-array
                                                        character
                                                        (1))
                                                       (fortran-to-lisp::integer4)
                                                       (fortran-to-lisp::integer4)
                                                       (double-float)
                                                       (array
                                                        double-float
                                                        (*))
                                                       (fortran-to-lisp::integer4)
                                                       (array
                                                        double-float
                                                        (*))
                                                       (fortran-to-lisp::integer4)
                                                       (double-float)
                                                       (array
                                                        double-float
                                                        (*))
                                                       (fortran-to-lisp::integer4))
          :return-values '(nil nil nil nil nil nil nil nil nil nil nil)
          :calls '(fortran-to-lisp::xerbla fortran-to-lisp::lsame))))

